<!--

    Copyright (c) 1997, 2018 Oracle and/or its affiliates. All rights reserved.

    This program and the accompanying materials are made available under the
    terms of the Eclipse Public License v. 2.0, which is available at
    http://www.eclipse.org/legal/epl-2.0.

    This Source Code may also be made available under the following Secondary
    Licenses when the conditions for such availability set forth in the
    Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
    version 2 with the GNU Classpath Exception, which is available at
    https://www.gnu.org/software/classpath/license.html.

    SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0

-->

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:ui="http://java.sun.com/jsf/facelets">
<h:head>
<title>Dynamic Component Addition</title>
<style type="text/css">
.grayBox { padding: 8px; margin: 10px 0; border: 1px solid #CCC; background-color: #f9f9f9;  }
</style>
</h:head>

<h:body>

  <ui:debug hotkey="p" rendered="true"/>

<h:form id="form">

  <p>

   Type some text <h:inputText id="textField" 
                               validator="#{dynamicStateBean.validateAddition}" />

  </p>

  <p>

    <h:outputText value="This text has a listener attached to it that adds the button with id cbutton">
      <f:event type="preRenderComponent" listener="#{dynamicStateBean.beforeRenderAddition}" />
    </h:outputText>

  </p>

  <p><h:commandButton value="reload" id="reload" /> </p>

  <p>Text inside the form, after the reload button.</p>

</h:form>

  <p>Text outside the form.</p>

</h:body>

</html>
